# K THU TVIX LÝ

Ch ng 6. VI I U KHI N 8051

- 1. C u trúc t ng quát c a m t vi i u khi n.
- 2. Vi i u khi n 8051
- 3. B m/ nh th i trong 8051
- 4. C ng n i ti p (UART) trong 8051
- 5. Ho t ng ng t trong 8051

1

# 6.1 C u trúc t ng quát c a m t vi i u khi n.

\* C u trúc bên trong c a vi i u khi n





# 6.1 C u trúc t ng quát c a m t vi i u khi n.

- \* Ki n trúc von-Neumann
  - ✓L nh và d li u c l u tr trong b nh c ghi chia s ;
  - ✓B nh c ánh a ch theo vùng, không ph thu c vào n i dung nó l u tr ;
  - $\checkmark$  Các l nh c a m t ch ng trình c th c hi n tu n t .
- ★ Ki n trúc von-Neumann th ng c s d ng trong các h vi x lý a n ng (nh máy tính PC)

# 6.1 C u trúc t ng quát c a m t vi i u khi n.

Ki n trúc Harvard



5

# 6.1 C u trúc t ng quát c a m t vi i u khi n.

- Ki n trúc Harvard
- ➤ B nh c chia thành 2 ph n:
  - ✓B nh 1 u mã ch ng trình
  - √B nh lud liu
- > CPU s d ng 2 h th ng bus giao ti p v i b nh :
  - ✓Bus A, D và C cho b nh ch ng trình
  - ✓Bus A, D và C cho b nh d li u
- ➤ Ki n trúc Harvard nhanh h n ki n trúc von-Neumann do b ng thông c a bus l n h n
- ❖ Các vi i u khi n th ng s d ng Ki n trúc Harvard.

# 6.1 C u trúc t ng quát c a m t vi i u khi n.

❖ S khác nhau gi a h th ng vi x lý công d ng chung và vi i u khi n



# 6.1 C u trúc t ng quát c a m t vi i u khi n.

M ts s n ph m c a h th ng nhúng s d ng v k

| Thiết bị nội thất gia<br>đình | Văn phòng       | ô tô                |  |
|-------------------------------|-----------------|---------------------|--|
| Đổ điện trong nhà             | Điện thoại      | Máy tính hành trình |  |
| Máy đàm thoại                 | Máy tính        | Điều khiển động cơ  |  |
| Máy điện thoại                | Các hệ thống an | Túi đệm khí         |  |
| Các hệ thống an toàn          | toàn            | Thiết bị ABS        |  |
| Các bộ mở cửa ga-ra           | Máy Fax         | Đo lường            |  |
| xe                            | Lò vi sóng      | Hệ thống bảo mật    |  |
| Máy trả lời                   | Máy sao chụp    | Đíũu khiển truyền   |  |
| Máy Fax                       | Máy in lazer    | tin                 |  |
| Máy tính gia đình             | Máy in màu      | Giải trí            |  |
| Tivi                          | Máy nhắn tin    | Điều hoà nhiệt độ   |  |
| Truyền hình cáp               |                 | Điện thoại tổ ong   |  |
| VCR                           |                 | Mở cửa không cần    |  |
| Máy quy camera                |                 | chìa khoá           |  |
| Điều khiển từ xa              |                 |                     |  |
| Trò chơi điện tử              |                 |                     |  |
| Điện thoại tổ ong             |                 |                     |  |



- . Gi i thi u chung
- Các chân tín hi u c a V K 8051
- \* T ch cb nh c a V K 8051
- ❖ Các ch a ch c a vi i u khi n 8051
- ❖ T pl nh c a vi i u khi n 8051
- \* Khung ch ng trình h p ng cho 8051.

9



#### 6.2 Vi i u khi n 8051

- . Gi i thi u chung
- > H V K 8051 hay MCS-51 c Intel công b vào n m 1980 v i chip 8051.
- ➤ MCS-51 là h vi i u khi n n chip 8bit ph d ng, c nhi u công ty bán d n hàng u th gi i ch t o: AMD, Siemens, TI, Philips, Dallas, Atmel, OKI,..
- ➤ Có kho ng vài tr m bi n th phát tri n t 8051, v i nhi u bi n th m nh h n nhi u so v i 8051. Ví d : chip MSC1211Y5 c a TI c óng v 64 chân, 4 c ng vào/ra 8bit, 8 kênh ADC 24bit, 4 b DAC 16bit, 2 c ng UART, 32KB Flash,...

# H

#### 6.2 Vi i u khi n 8051

- Các ctr ng c b n c a chip 8051:
  - ✓ 4 KB ROM / 128 Byte RAM trong
  - ✓ 32 ng vào/ra hai h ng, t o thành 4 c ng 8bit là P0, P1, P2, P3.
  - ✓ Hai b m/ nh th i 16 bit
  - ✓ B truy n thông n i ti p không ng b ki u song công(UART)
  - √ Không gian b nh ch ng trình ngoài có th m r ng lên n 64KB
  - ✓ Không gian b nh d li u ngoài có th m r ng lên n 64KB
  - ✓ CPU 8bit r t thích h p dùng trong các h i u khi n
  - ✓ 210 v trí nh c nh a ch, m i v trí m t bit
  - ✓ Có 5 ngu n ng t v i 2 m c u tiên
  - ✓ Có 1 nh nhân, chia 8bit th c hi n trong 4µs

11

# 6.2 Vi i u khi n 8051

Các ctr ng c b n c a chip 8051:





# 6.2 Vi i u khi n 8051 ★ Các chân tín hi u c a V K 8051: ➤ C ng P0 (39..32): • C ng xu t/nh p hai h ng • D n kênh Bus a ch (8bit th p) và Bus d li u ➤ C ng P1 (1..8): • C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ C ng xu t/nh p hai h ng ➤ Dùng cho truy n thông n i ti p, ng t ngoài, b m nh th i và các tín hi u i u khi n truy xu t b nh d li u ngoài

❖ Các chân tín hi u c a V K 8051:

➤ Ví d 1: G i ra c ng P0 các giá tr 55H và AAH

MOV A, #55H

BACK: MOV P0, A

ACALL DELAY

CPL A

SJMP BACK

➤ Ví d 2: T o xung vuông chân P2.1

AGAIN: SETB P2.1

ACALL DELAY

CLR P2.1

ACALL DELAY

SJMP AGAIN

15

# 6.2 Vi i u khi n 8051

| Bit  | Tên   | a ch<br>bit | Ch c n ng                           |
|------|-------|-------------|-------------------------------------|
| P3.0 | RxD   | ВОН         | Chân nh n d li u c a port n i ti p. |
| P3.1 | TxD   | B1H         | Chân phát d li u c a port n i ti p. |
| P3.2 | /INT0 | В2Н         | Ngõ vào ng t ngoài 0.               |
| P3.3 | /INT1 | ВЗН         | Ngõ vào ng t ngoài 1.               |
| P3.4 | ТО    | В4Н         | Ngõ vào c a b nh th i/ m 0.         |
| P3.5 | T1    | В5Н         | Ngõ vào c a b nh th i/ m 1.         |
| P3.6 | /WR   | В6Н         | i u khi n ghi b nh d li u ngoài.    |
| P3.7 | /RD   | В7Н         | iukhin сь nh ngoàid lių.            |



- ❖ Các chân tín hi u c a V K 8051:
- ► /PSEN (29): chân i u khi n cho phép c các byte l nh t b nh ch ng trình ngoài (n i t i OE c a ROM ngoài).
- ➤ ALE (30): tín hi u ch t a ch
- > /EA: cho phép ch n b nh ch ng trình trong hay ngoài
  - /EA n i v i 5V: ch ng trình trong ROM n i c th c thi
  - /EA n i v i GND: ch ng trình trong ROM ngoài c th c thi
  - Chân /EA còn c s d ng làm chân nh n i n áp c p i n (Vpp) cho vi c l p trình EPROM, EEPROM, flash ROM n i
- ➤ RST (9): ngỗ vào Reset c a vi i u khi n. V K s c Reset khi t RST m c logic 1 t i thi u 2 chu k máy.
- ➤ XTAL1 và XTAL2: dùng ghép v i th ch anh bên ngoài c p ngu n xung nh p cho V K.

17



#### 6.2 Vi i u khi n 8051

- ❖ T ch c b nh c a V K 8051:
- > T ch c b nh theo ki n trúc Harvard: tách bi t gi a b nh ch ng trình và b nh d li u.
- ➤ B nh ch ng trình
- ➤ B nh d li u
- Các thanh ghi ch c n ng c bi t



- □ B nh ch ng trình
- ➤ B nh ch ng trình có th là ROM trong ho c ROM ngoài.
- Vi c ch n b nh ch ng trình là ROM trong hay ROM ngoài ph thu c vào tín hi u /EA.
  - -/EA n i v i +5V: B nh trong
  - /EA n i v i +0V: B nh ngoài
- Ph n a ch th p nh t c a b nh ch ng trình ch a b ng vector ng t. ây chính là a ch b t u c a các ch ng trình con ph c v ng t.
- a ch b nh ch ng trình luôn là 16bit





#### 6.2 Vi i u khi n 8051

- □ B nh d li u
- ➤ B nh d li u bao g m 2 ph n là RAM n i ( bên trong chip) và RAM ngoài.
- Vùng stack th ng trú trong RAM trên chip
- ➤ B nh d li u n i c chia thành:
  - √ Vùng các dãy thanh ghi (00H ÷ 1FH)
  - ✓ Vùng RAM nh a ch bit  $(20 \div 2FH)$
  - ✓ Vùng RAM a m c ích (30H ÷ 7FH)
  - ✓ Các thanh ghi ch c n ng c bi t (80H ÷ FFH)



# H

#### 6.2 Vi i u khi n 8051

□ B nh d li u: Vùng RAM nh a ch

MOV 2CH,A

- ➤ 8051 ch a 210 v trí c nh a ch bit ch a trong các byte t a ch 20H n 2FH và trong các thanh ghi ch c n ng c bi t.
- Các a ch này c truy xu t theo byte ho c theo bit
  Ví d: SETB 67H; thi t l p bit 67H b ng l
  L nh trên t ng ng v i:
  MOV A, 2CH; c c byte
  ORL A, #10000000B; set bit MSB



- ☐ B nh d li u: Các dãy thanh ghi
- ➤ 32 v trí th p nh t t 00H n 1FH ch a 4 dãy thanh ghi. 8 thanh ghi t R0 n R7 c ghép thành m t dãy.
- truy c p n thanh ghi có 2 cách:

MOV A, R5; c n i dung t i a ch 05H vào A

MOV A,05H; c a ch tr c ti p

➤ Dãy thanh ghi ang c s d ng g i là dãy thanh ghi tích c c. Dãy thanh ghi tích c c có th c thay i b ng các bit ch n dãy trong t tr ng thái PSW

23



#### 6.2 Vi i u khi n 8051

- ☐ Các thanh ghi ch c n ng c bi t
- Các thanh ghi ch c n ng c bi t c a 8051 c c u hình thành m t ph n c a RAM trên chip.
- ➤ Vùng RAM n i dành cho các thanh ghi ch c n ng c bi t có a ch t 80H n FFH. Tuy nhiên ch có 21 a ch c s d ng cho 21 thanh ghi ch c n ng c bi t t ng ng c a 8051.
- Các thanh ghi ch c n ng c bi t ch có th truy xu t thông qua ch a ch tr c ti p.
- M t s thanh ghi c nh a ch bit. a ch các bit trong các thanh ghi này b ng a ch Byte c ng v trí c a bit.

- ☐ Các thanh ghi ch c n ng c bi t: Thanh ghi tích l y
  - Ký hi u là ACC (t ng ng v i a ch E0h), c nh a ch t ng bit
  - Th ng là toán h ng ích trong các l nh s h c và logic, k t qu c a l nh ch a trong thanh ghi A



25

# 6.2 Vi i u khi n 8051

- ☐ Các thanh ghi ch c n ng c bi t
- > T tr ng thái ch ng trình PSW

| tr ng thai ch |         | ng trii | in PSW                               |    |
|---------------|---------|---------|--------------------------------------|----|
| Bit           | Ký hiệu | Địa chi | Mô tả bit                            |    |
| PSW.7         | CY      | D7H     | Cờ nhớ                               |    |
| PSW.6         | AC      | D6H     | Cờ nhớ phụ                           |    |
| PSW.5         | FO      | D5H     | Съ 0                                 |    |
| PSW.4         | RS1     | D4H     | Chọn dãy thanh ghi ( bit 1 )         |    |
| PSW.3         | RS0     | D3H     | Chọn dãy thanh ghi ( bit 0 )         |    |
|               |         |         | 00 = bank 0 : dịa chỉ từ 00H đến 07H |    |
|               |         |         | 01 = bank 1 : dịa chỉ từ 08H đến 0FH |    |
|               |         |         | 10 - bank 2 : dịa chỉ từ 10H đến 17H |    |
|               |         |         | 11 = bank 3 : dịa chỉ từ 18H đến 1FH |    |
| PSW.2         | ov      | D2H     | Cờ tràn                              |    |
| PSW.1         | -       | D1H     | Dự trữ                               |    |
| PSW.0         | P       | D0H     | Cờ kiểm tra chấn lễ                  | 26 |



- ☐ Các thanh ghi ch c n ng c bi t
- > Thanh ghi B
  - a ch là F0h, c nh a ch t ng bit
  - c dùng kèm v i thanh ghi A trong các phép toán nhân, chia hay dùng nh m t thanh ghi a d ng
- > Thanh ghi con tr d li u
  - Là thanh ghi 16 bit
  - c dùng xác nha ch b nh ngoài

Ví d: ghi 55H vào RAM ngoài có a ch 1000h

MOV A,#55H

MOV DPTR,#1000H

MOV @DPTR,A; di chuy n 55h n a ch ch a trong DPTR



#### 6.2 Vi i u khi n 8051

- ☐ Các thanh ghi ch c n ng c bi t
- > Các thanh ghi port
  - G m 4 thanh ghi t ng ng v i 4 port

P0 ⇔ Port 0 : ở địa chỉ 80H

P1 ⇔ Port 1 : ở địa chỉ 90H

P2 ⇔ Port 2 : ở địa chỉ A0H

P3 ⇔ Port 3 : ở địa chỉ B0H

• Ví d 1: N i ng c v i bit 7 c a port 1. Ta có th thi t1 p ho t ng c a ng c b ng l nh: SETB P1.7 ho c CLR P1.7



- ☐ Các thanh ghi ch c n ng c bi t
- $\triangleright$  Contr ng n x p (SP)
  - Stack là ng n nh trên RAM 1 u thông tin t m th i
  - The ngly vùng nh t 30 7F là ng nx p.
- Các thanh ghi b nh th i:
  - Timer 0 g m TL0 và TH0
  - Timer 1 g m TL1 và TH1
  - TMOD c dùng thi t l p ch ho t ng c a Timer 0 và Timer 1
  - TCON c dùng i u khi n ho t ng c a Timer 0 và Timer 1.

20



#### 6.2 Vi i u khi n 8051

- ☐ Các thanh ghi ch c n ng c bi t
- ➤ Thanh ghi c ng n i ti p
  - ➤ 8051 ch a m t c ng n i ti p trên chip dành cho vi c trao i thông tin v i thi t b ngo i vi.
  - ➤ Thanh ghi SBUF (serial buffer) dùng 1 u d li u tr c khi truy n ho c nh n d li u.
  - Thanh ghi SCON dùng i u khi n ch truy n c a c ng n i ti p.



- ☐ Các thanh ghi ch c n ng c bi t
- > Thanh ghi ng t
  - ➤ 8051 có 5 ngu n ng t:

| Ngắt                          | Địa chỉ ROM | Chân      |
|-------------------------------|-------------|-----------|
| Bật lại nguồn (RESET)         | 0000        | 9         |
| Ngắt phần cứng ngoài (INT0)   | 0003        | 12 (P3.2) |
| Ngắt bộ Timer0 (TF0)          | 000B        | ,         |
| Ngắt phần cứng ngoài 1 (INT1) | 0013        | 13 (P3.3) |
| Ngắt bộ Timer1 (TF1)          | 001B        |           |
| Ngắt COM nói tiếp (RI và TI)  | 0023        | 9         |

- Thanh ghi IE quy t nh ng t nào c phép ho t ng.
- ➤ Vi c xác l p ch u tiên ng t thông qua thanh ghi IP (Interrupt Priority)

21



# 6.2 Vi i u khi n 8051

- ❖ T pl nh c a vi i u khi n 8051:
- T p1 nh c a 8051 có th chia thành 5 nhóm:
  - Nhóm l nh s h c
  - Nhóm 1 nh logic
  - Nhóm l nh di chuy n d li u
  - Nhóm 1 nh x 1ý bit
  - Nhóm l nh r nhánh

G c, ích: có th là Rn, ho c direct ho c @Ri data: h ng s 8 bit data16: h ng s 16bit

- □ Nhóm l nh s h c
  - **ADD** A, G c
  - ADD A,#data
  - ADDCA, G c
  - ADDC A, #data
  - SUBBA,G c
  - SUBB A,#data
  - INC A
  - INC G c
  - **DEC** A
  - DEC G c
  - **INC** DPTR
  - MUL AB ; K t qu : A = byte th p, B = byte cao
  - **DIV** AB ; A:B, A = th ng, B = d

33



#### 6.2 Vi i u khi n 8051

- ❖ Các ch a ch c a vi i u khi n 8051:
- ➤B V K 8051 có 8 ki u nh a ch:
  - Thanh ghi (register) MOV A, R0
    - L u ý: MOV R1, R0: Không h p1
  - Tr c ti p (direct) MOV R0,40H
  - Gián ti p (Indirect) MOV A, @R1
  - T c th i (Immediate) MOV A, #55H
  - Ch s (Indexed) MOVC A, @A+DPTR

# ٠

# 6.2 Vi i u khi n 8051

Ví d: Vi t ch ng trình g i 55H n c ng P1 và P2 s d ng:

a. Tên các c ng

MOV A, #55H

MOV P1, A

MOV P2, A

a. a ch các c ng

MOV A, #55H

**MOV 80H, A** 

MOV 0A0H,A

35

# Н

#### 6.2 Vi i u khi n 8051

Ví d: Vi t ch ng trình y thanh ghi R5, R6 và A vào ng n x p và sau ó l y các giá tr ng c tr l i thanh ghi R2, R3 và B t ng ng

PUSH 05

**PUSH 06** 

PUSH 0E0H

POP 0F0H

**POP 02** 

**POP 03** 



Ví d: Vi t ch ng trình sao chép giá tr 55H vào ng n nh RAM t a ch 40H n 44H s d ng:

- a. Ch ánh a ch tr c ti p
- b. Ch ánh a ch gián ti p thanh ghi
- c. Ch b có dùng vòng l p

37

# ۲

## 6.2 Vi i u khi n 8051

MOV A,#55H

MOV R0,#40H MOV R2,#05H

AGAIN: MOV @R0,A

INC R0

DJNZ R2,AGAIN



Ví d: Vi t ch ng trình xóa 16 v trí ng n nh RAM b t u t i a ch 60H.

Ví d: Vi t ch ng trình sao chép m t kh i 10 byte d li u t v trí ng n nh RAM b t u t 35H vào các v trí ng n nh RAM b t u t 60H

39



#### 6.2 Vi i u khi n 8051

- □ Nhóm l nh s h c
  - ☐ Ví d: Vi t ch ng trình c ng hai s 16 bit. Các s ó là 3CE7H và 3B8DH. K t qu 1 u vào R7 (byte cao) và R6 (byte th p)

CLR PSW

MOV A,#0E7H

ADD A,#8DH

MOV R6,A

MOV A,#3CH

ADDC A,#3BH

MOV R7,A

#### 6.2 Vi i u khi n 8051 ☐ Nhóm 1 nh logic ANL A, G c ; AND ANL A, #data ANL direct, A ANL direct,#data ORLA, G c ; OR ORL A,#data ORL direct, A ORL direct, #data XRL A, G c ; XOR XRL A, #data XRL direct, A XRL direct, #data CLR A ; Clear $\mathbf{CPL}\,\mathbf{A}$ ; Complement **RL** A ; Rotate Accumulator Left **RLC** A ; Rotate Accumulator Left through Carry $\mathbf{RR} \, \mathbf{A}$ $\boldsymbol{RRC}\,\boldsymbol{A}$ SWAP A 41

#### 6.2 Vi i u khi n 8051 Nhóm l nh thao tác trên bit CLR ; Xóa bit c nh CY CLR bit **SETB** C **SETB** bit CPL C CPL bit ANL C,bit ; AND c nh CY v i bit ANL C,/bit ; AND c nh CY v i bit o **ORL** C,bit ORL C,/bit MOV C,bit MOV bit,C JC Nhãn ;( 1 ch:-128...127) JNC Nhãn ;( 1 ch:-128...127) JB bit,Nhãn ; Nh y n nhãn n u bit = 1JNB bit,Nhãn ; Nh y n nhãn n u bit =0JBC bit,Nhãn ;nh y n u bit b ng 1 r i xoá bit



Ví d: Tìm t ng c a các giá tr 79H, F5H và E2H. t vào trong các thanh ghi R0 (byte th p) và R5 (byte cao)

Ví d: Các ng n nh t 40 n 44 ch a các giá tr sau: 40 = 4DH, 41 = EBH, 42 = C5H, 43 = 5BH, 44 = 30H. Tính t ng c a các giá tr trên. Thanh ghi A ch a byte th p và thanh ghi R7 ch a byte cao

43



## 6.2 Vi i u khi n 8051

Ví d: Tìm t ng c a các giá tr 79H, F5H và E2H. t vào trong các thanh ghi R0 (byte th p) và R5 (byte cao)

MOV R5,#0

MOV A,#79H

ADD A,#F5H

JNC next

INC<sub>R5</sub>

Next: ADD A,E2H

JNC exit

INC R5

Exit: MOV R0,A



Ví d: Các ng n nh t 40 n 44 ch a các giá tr sau: 40 = 4DH, 41 = EBH, 42 = C5H, 43 = 5BH, 44 = 30H. Tính t ng c a các giá tr trên. Thanh ghi A ch a byte th p và thanh ghi R7 ch a byte cao

MOV R0, #40H

MOV R2, #5

CLR A

CLR R7

AGAIN: ADD A,@R0

> JNC **NEXT**

INC R7

NEXT: INC R0

DJNZ R2,AGAIN

45



#### 6.2 Vi i u khi n 8051

- Nhóm l nh chuy n d li u
  - MOV A,G c
  - MOV A,#data
  - MOV ích,A
  - MOV ích,G c
  - MOV ích.#data
  - MOV DPTR,#data16
  - MOVC A,@A+DPTR ; Move code byte to accumulator
  - **MOVC** A,@A+PC
  - MOVX A,@Ri ; Move data from external memory to A
  - MOVX A,@DPTR
  - MOVX @Ri,A
  - MOVX @DPTR,A
  - PUSH direct
  - **POP** direct
  - XCH A,G c i các byte ;trao

**XCHD** A,@Ri i các digit th p ;trao



#### ☐ Nhóm l nh r nhánh

ACALL addr ; Pham vi 2KLCALL addr ; Ph m vi 64K

RET

• RETI

AJMP Nhãn ; (Ph m vi 2K)
 LJMP Nhãn ; (Ph m vi 64 K)
 SJMP Nhãn ; (1 ch:-128...127)

• **JMP** @A+DPTR

JZ Nhãn ; ( 1 ch: -128...127) nh y n u A = 0
 JNZ Nhãn ; ( 1 ch: -128...127) nh y n u A # 0
 CJNE A, direct, Nhãn; Compare and Jump if not equal

• **CJNE** A, #data, Nhãn;

CJNE Rn,#data, Nhãn

CJNE @Ri,#data,Nhãn

DJNZ Rn,Nhãn

• DJNZ direct,Nhãn

NOP

47



#### 6.2 Vi i u khi n 8051

- ❖ Khung ch ng trình h p ng cho 8051
- Các ch d n th ng dùng khi l p trình:

✓ ORG (set origin)

D ng ch d n ORG nh sau:

ORG bi u th c

Ch d n ORG thay i n i d ng b m v trí thi t l p m t g c m i c a ch ng trình cho các phát bi u theo sau

✓ END

D ng c a ch d n END nh sau:

**END** 

END là phát bi u cu i cùng c a ch ng trình ngu n. Không có gì theo sau phát bi u END c s lý b i trình d ch h p ng



- ❖ Khung ch ng trình h p ng cho 8051
- Các ch d n th ng dùng khi l p trình:
  - ✓ EQU (equate)

D ng c a ch d n EQU nh sau:

TÊN EQU Bi u\_th c

Ch d n EQU gán giá tr s cho  $T\hat{E}N$ . Bi u\_th c là m t h ng s hay m t bi u th c ch a các h ng s . VD:

X1 EQU 35H; X1 có giá tr 35H Khi biên d ch TÊN s c thay th b ng giá tr ã gán cho nó t i nh ng n i nó xu t hi n trong ch ng trình.

49



#### 6.2 Vi i u khi n 8051

- ❖ Khung ch ng trình h p ng cho 8051
- Các ch d n th ng dùng khi l p trình:

✓ DB

D ng c a ch d n DB nh sau:

[Nhãn:] DB Giá\_tr [,Giá\_tr , ...]

Ch d n DB kh i ng 1 vùng nh mã (các ô nh trong b nh ch ng trình) v i các giá tr có dài 1 byte. Trên th c t ch d n này th ng c dùng t các h ng s vào b nh ch ng trình. Danh sách các giá tr là m t chu i c a m t hay nhi u giá tr byte cách nhau b i d u ph y.

VD:

Ma7Vach: DB 40H,79H,24H,30H

Chao: DB "HELLO" ; chu i ký t

(DB = 48H, 45H, 4CH, 4CH, 4FH)



- ❖ Khung ch ng trình h p ng cho 8051
- Các ch d n th ng dùng khi l p trình:

```
✓ DW
```

D ng c a ch d n DW nh sau:

[Nhãn:] DW Giá\_tr [,Giá\_tr,...]

Ch d n DW t ng t nh ch d n DB ngo i tr 2 v trí nh (16bit) c gán cho m i thành ph n d li u.

VD:

MW: DW 12H, 345H, 555H (DW = 00H, 12H, 03H, 45H, 05H, 55H)

51



#### 6.2 Vi i u khi n 8051

❖ Khung ch ng trình h p ng khi không s d ng ng t:

```
; [Tên ch ng trình] - [Mô t ch ng trình]
```

; Khai báo bi n ( t tên cho các ô nh )

[Tên\_bi n] EQU [ a\_ch ] ; Mô t bi n

; Khai báo h ng

[Tên\_h ng EQU Giá\_tr]; Môt h ng

; B t u ch ng trình chính

ORG 0000H

MAIN:

; Các l $\,$ nh c $\,$ a thân ch $\,$ ng trình chính

CALL Tên\_ctc; G i ch ng trình con

; B t u các ch ng trình con



❖ Khung ch ng trình h p ng khi không s d ng ng t:

; B t u các ch ng trình con Tên\_ctc:

;Các l $\,$ nh c $\,$ a thân ch $\,$   $\,$ ng trình con

.....

RET ; K t thúc ch $\,$  ng trình con và quay v  $\,$  ch $\,$  ng trình chính ; Các ch $\,$  ng trình con khác

.....

\*\*\*\*\*\*\*\*\*\*

; K t thúc toàn b ch ng trình

**END** 

➤ Ví d: i u khi n m t led 7 o n n i v i c ng P0 hi n th 1 n 1 t các s t 0 n 9. M i giá tr hi n th trong 250ms. Bi t P0.0....P0.61 n 1 t n i v i các led a....g c a led 7 v ch, led 7 v ch là lo i Anot chung.

53



#### 6.2 Vi i u khi n 8051

❖ Khung ch ng trình h p ng khi s d ng ng t:

; [Tên ch ng trình] - [Mô t ch ng trình]

; Khai báo bi n

[Tên\_bi n] EQU [ a\_ch ] ; Mô t bi n

; Khai báo h ng

[Tên\_h ng EQU Giá\_tr]; Môt h ng

; B t u ch ng trình

ORG 0000H; i m nh p c a ct chính, th c hi n sau khi RESET

LJMP MAIN

ORG 0003H; i m nh p c a ng t ngoài 0 (INT0)

LJMP SINTO

ORG 000BH; i m nh p c a ng t b nh th i 0 (TIM0)

LJMP STIM0

ORG 0013H; i m nh p c a ng t ngoài 1 (INT1)

LJMP SINT1

ORG 001BH; i m nh p c a ng t b nh th i 1 (TIM1)

LJMP STIM1

# ٧

## 6.2 Vi i u khi n 8051

```
❖ Khung ch ng trình h p ng khi s d ng ng t:
      ORG 0023H
                   ; i m nh p c a ng t c ng n i ti p (Serial Port)
        LJMP SSP
      ; B t u ch ng trình chính
      ORG 0030H
      MAIN:
             ; Các l nh c a thân ch ng trình chính
             [SJMP $; K t thúc ch ng trình chính]
      *********
      ; B t u các ch ng trình con th ng
      Tên_ctc:
             ;Các l nh c a thân ch ng trình con
             ; K t thúc ch ng trình con và quay v ch ng trình chính
      RET
      ; Các ch ng trình con khác
      *********
                                                             55
```



#### 6.2 Vi i u khi n 8051



# 6.3 B m/ nh th i trong 8051

- Nguyên lý ho t ng c b n c a b nh th i
- Các thanh ghi dùng cho b m/ nh th i
- \* Các ch nh th i
- Ngu n xung Clock cho b nh th i
- Kh i ng, d ng và truy xu t các thanh ghi c a b nh th i

57



# 6.3 B m/ nh th i trong 8051

- Chu k máy
- Khi th c hi n m t l nh, CPU c n m t vài chu k máy th c hi n.
- > 8051 s d ng m t b dao ng trong chip t o ra chu k máy.
- i u khi n b dao ng trong chip, 8051 c n m t b t o dao ng b ng th ch anh bên ngoài.
- > Chu k dao ng bên trong =  $12 \times chu \times dao$  ng th ch anh.
- ➤ Thông th ng, t n s dao ng th ch anh b ng 11.0592MHz

# 4

# 6.3 B m/ nh th i trong 8051

Chu k máyV i chu k máy = 1.085 μs

#### Machine cycles Time to execute Instruct (a) MOV R3, #55 1 $1 \times 1.085 \ \mu s = 1.085 \ \mu s$ (b) DEC R3 $1 \times 1.085 \ \mu s = 1.085 \ \mu s$ (c) DJNZ R2, target 2 $2 \times 1.085 \; \mu s = 2.17 \; \mu s$ 2 (d) LJMP $2 \times 1.085 \ \mu s = 2.17 \ \mu s$ (e) SJMP 2 $2 \times 1.085 \ \mu s = 2.17 \ \mu s$ 1 (f) NOP $1 \times 1.085 \ \mu s = 1.085 \ \mu s$ 4 (g) MUL AB $4 \times 1.085 \ \mu s = 4.34 \ \mu s$

59

# Ŋ

# 6.3 B m/ nh th i trong 8051

Chu k máy

Tính th i gian tr c a hàm DELAY:

Machine Cycle DELAY: MOV R3,#250 1

HERE: NOP

NOP 1 NOP 1 NOP 1 NOP 1 DJNZ R3,HERE 2

 $\{ [250 (1+1+1+1+2)] + 3 \} \times 1.085 \mu s = (1500+2) \times 1.085 \mu s = 1629.67 \mu s.$ 

#### 6.3 B m/ nh th i trong 8051

Chu k máy

Tính th i gian tr c a hàm DELAY:

| DELAY: |               | <i>Machine Cycle</i> |
|--------|---------------|----------------------|
|        | MOV R2,#200   | 1                    |
| AGAIN: | MOV R3,#250   | 1                    |
| HERE:  | NOP           | 1                    |
|        | NOP           | 1                    |
|        | DJNZ R3,HERE  | 2                    |
|        | DJNZ R2,AGAIN | 2                    |
|        | RET           | 2                    |

61

#### 6.3 B m/ nh th i trong 8051

- Nguyên lý ho t ng c b n c a b
- Tns cab nh th i luôn b ng 1/12 t n s c a th ch anh g n v i 8051
- a) 12MHz
- b) 16MHz
- c) 11,0592MHz



a) 
$$\frac{1}{12} \times 12 \text{MHz} = 1 \text{MHz} \text{ và } T = \frac{1}{1/1 \text{MHz}} = 1 \mu \text{s}$$

b) 
$$\frac{1}{12} \times 16\text{MHz} = 1.111\text{Mz} \text{ và } T = \frac{1}{1.333\text{MHz}} = 0.75 \mu\text{s}$$

a) 
$$\frac{1}{12} \times 12 \text{MHz} = 1 \text{MHz} \text{ và } T = \frac{1}{1/1 \text{MHz}} = 1 \mu \text{s}$$
  
b)  $\frac{1}{12} \times 16 \text{MHz} = 1,111 \text{Mz} \text{ và } T = \frac{1}{1,333 \text{MHz}} = 0,75 \mu \text{s}$   
c)  $\frac{1}{12} \times 11,0592 \text{MHz} = 921,6 \text{kHz} \text{ và } T = \frac{1}{0,9216 \text{MHz}} = 1,085 \mu \text{s}$ 

# 6.3 B m/ nh th i trong 8051

- Nguyên lý ho t ng c b n c a b nh th i
- B nh th i ho t ng d a trên c s b m xung nh phân
- Khi ho t ng nó s m ti n t 0 hay t m t giá tr t tr c nào ó cho n giá tr l n nh t (FFFFH v i b nh th i 16bit) mà nó có kh n ng bi u di n. N i dung b th i t ng l n v khi nh n c m t xung u vào.
- Khi ang giá tr l n nh t, n u có thêm m t xung nh p c a t i thì n i dung c a b nh th i s quay v giá tr 0, ng th i c báo tràn t ng ng c t lên m c tích c c.



63

# P,

# 6.3 B m/ nh th i trong 8051

- Các thanh ghi dùng cho b m/ nh th i
- V K 8051 có hai b m/ nh th i 16bit. Các b nh th i này c truy xu t và i u khi n thông qua 6 thanh ghi ch c n ng t bi t

| Thanh ghi | Mô t                      | a ch | nh /ch bit |
|-----------|---------------------------|------|------------|
| TCON      | Thanh ghi i u khi n       | 88H  | Có         |
| TMOD      | Thanh ghi ch n ch         | 89H  | Không      |
| TL0       | Byte th p c a b nh th i 0 | 8AH  | Không      |
| TH0       | Byte cao c a b nh th i 0  | 8CH  | Không      |
| TL1       | Byte th p c a b nh th i1  | 8BH  | Không      |
| TH1       | Byte cao c a b nh th i    | 8DH  | Không      |

# 6.3 B m/ nh th i trong 8051

- ❖ Các thanh ghi dùng cho b m/ nh th i
- > Thanh ghi TMOD:

√ Thanh ghi TMOD c dùng thi t 1 p ch
ho t ng cho các b nh th i: 4bit cao dùng cho b
nh th i 1, 4bit th p dùng cho b nh th i 0

| GATE1 | C//T1 | M11 | M10 | <b>GATE0</b> | C//T0 | M01 | M00 |
|-------|-------|-----|-----|--------------|-------|-----|-----|
| _     |       |     | _   | _            |       | -   |     |

65

# P,

# 6.3 B m/ nh th i trong 8051

## > Thanh ghi TMOD:

| Bit | Ký hi u  | Mô t                                                               |
|-----|----------|--------------------------------------------------------------------|
| 0-1 | M00,     | Các bit ch n ch cho TIMER0                                         |
|     | M01      | 00: Ch 0, b nh th i 13bit                                          |
|     |          | 01: Ch 1, b nh th i 16bit                                          |
|     |          | 10: Ch 2, b nh th i 8bit t ng n p l i                              |
|     |          | 11: Ch 3, ch chia x . Timer0 ho t ng nh hai b nh th i 8bit.        |
| 2   | C//T0    | Bit ch n ch c n ng m/ nh th i cho Timer0: 1: m s ki n              |
|     |          | 0: nh th i                                                         |
| 3   | GATE0    | Bit i u khi n c ng. Khi Gate = 1, Timer0 ch ho t ng khi/INT0 =1.   |
| 4-5 | M10, M11 | Các bit ch n ch cho TIMER1                                         |
|     |          | 00: Ch 0, b nh th i 13bit                                          |
|     |          | 01: Ch 1, b nh th i 16bit                                          |
|     |          | 10: Ch 2, b nh th i 8bit t ng n p l i                              |
|     |          | 11: D ng, không ho t ng.                                           |
| 6   | C//T1    | Bit ch n ch c n ng m/ nh th i cho Timer1: 1: m s ki n              |
|     |          | 0: nh th i                                                         |
| 7   | GATE1    | Bit i u khi n c ng. Khi Gate = 1, Timer1 ch ho t ng khi /INT1 = 1. |





# Ŋ

# 6.3 B m/ nh th i trong 8051

#### > Thanh ghi TCON:

√ Thanh ghi TCON có a ch là 88H, ây là thanh ghi c
nh a ch bit. TCON ch a các bit i u khi n và tr ng thái c a
các b nh th i

| Bit    | Ký hi u | a ch bit | Mô t                                                                                                                                 |
|--------|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------|
| TCON.7 | TF1     | 8FH      | C tràn c a Timer1. TF1 c set b ng ph n c ng, c xoá b ng ph n m m ho c b i ph n c ng khi b V K th c hi n ch ng trình con ph c v ng t. |
| TCON.6 | TR1     | 8EH      | Bit i u khi n ch y/d ng c a Timer1. TR1 c set/reset b ng ph n m m cho phép Timer1 ho t ng hay ng ng ho t ng.                         |
| TCON.5 | TF0     | 8DH      | C tràn c a Timer0.                                                                                                                   |
| TCON.4 | TR0     | 8CH      | Bit i u khi n ch y/d ng c a Timer0.                                                                                                  |
| TCON.3 | IE1     | 8BH      | C ng t ngoài INT1                                                                                                                    |
| TCON.2 | IT1     | 8AH      | t ch cho ng t ngoài INT1                                                                                                             |
| TCON.1 | IE0     | 89H      | C ng t ngoài INT0                                                                                                                    |
| TCON.0 | IT0     | 88H      | t ch cho ng t ngoài INTO 69                                                                                                          |

# r,

# 6.3 B m/ nh th i trong 8051

- \* Các ch nh th i
- Các b nh th i c a 8051 có th ho t ng 4 ch
   . Các ch này c ch n thông qua thanh ghi
   TMOD

#### > Ch 0: b nh th i 13bit

y Byte cao c a b nh th i THx (x=0 ho c 1) c ghép n i ti p v i 5bit th p c a byte th p TLx c a b nh th i t o thành m t b nh th i 13bit



Chế độ 0, bộ định thời 13bit

# 6.3 B m/ nh th i trong 8051

- Các ch nh th i
- > Ch 1: b nh th i 16bit
  - ✓ 2 thanh ghi THx và TLx c s d ng t o thành b nh th i 16bit.
  - ✓ Khi có xung clock n b nh th i s m ti n. M t tràn s x y ra khi có s chuy n s m t FFFFH xu ng 0000H và t c tràn TFx b ng 1. TFx sau ó có th c c và xoá b i ph n m m. Sau khi tràn b nh th i s ti p t c m t giá tr 0000H.



71

# 6.3 B m/ nh th i trong 8051

- \* Các ch nh th i
- > Ch 2: b nh th i 8bit t ng n p l i
  - ✓ Byte th p c a b nh th i TLx làm vi c nh m t b nh th i 8bit còn byte cao THx ch a giá tr n p l i.
  - ✓ Khi s m tràn t FFH v 00H, c tràn TFx s c t lên 1 ng th i giá tr trong THx c n p vào trong TLx và b nh th i ti p t c làm vi c t giá tr này cho n khi x y ra m t tràn k ti p.



Chế độ 2, bộ định thời 8bit tự động nạp lại

#### ٧

#### 6.3 B m/ nh th i trong 8051

- Các ch nh th i
- > Ch 3: b nh th i chia s
  - ✓ B nh th i 0 c chia thành 2 b nh th i 8bit ho t ông riêng r là TL0 và TH0. TL0 s d ng các bit i u khi n c a Timer0 và c TF0. TH0 s d ng các bit i u khi n c a Timer1 và c và TF1.
  - ✓ B nh th i 1 không ho t ng ch 3, nh ng có th kh i ng b nh th i này b ng cách chuy n nó vào 1 trong các ch khác. B nh th i 1 trong ch này có th c s d ng b i c ng n i ti p ho c c s d ng cho nh ng ng d ng nh th i mà không s d ng ng t

#### Н

#### 6.3 B m/ nh th i trong 8051

- Ngu n xung Clock cho b nh th i
- Có 2 l a ch n ngu n xung Clock cho các b nh th i c th c hi n thông qua vi c thi t l p bit C//T c a thanh ghi TMOD b ng 0 hay 1
- > nh th im t kho ng th i gian
  - ✓ N u C//T = 0, Xung clock c p cho b nh th i b ng 1/12 t n s dao ng c a th ch anh g n vào chip. B nh th i s tràn sau m t s xung clock xác nh ph thu c vào giá tr ban u n p cho các thanh ghi nh th i (TLx/THx). Th i gian tr t o ra t khi n p giá tr cho b nh th i n khi nó tràn s là:

### H

#### $\overline{6.3}$ B m/ nh th i trong 8051

- Các b c l p trình ch Mode 1.
- 1. N p giá tr TMOD cho thanh ghi Timer0 ho c Timer1
- 2. N p các thanh ghi TL và TH giá tr m ban u
- 3. Kh i ng b nh th i
- 4. Ki m tra c tràn TF b ng 1 nh "JNB TFx, nhãn". Thoát vòng l p khi TFx = 1.
- 5. D ng b nh th i
- 6. Xóa c TF cho vòng k ti p
- 7. Quay tr 1 i b c 2 n p l i TH và TL

75

#### ٧

#### 6.3 B m/ nh th i trong 8051

nh th i m t kho ng th i gian

+ Ch 16bit:

TimeDelay = [12\*(65536 - InitValue)]/F

Trong ó

InitValue = TLx + (256\*THn) = 65536 - TimeDelay\*F/12

F: t n s c a th ch anh.

+ Ch 8bit:

TimeDelay = [12\*(256-THx)]/F

 $\Rightarrow$  THx = 256 – TimeDelay\*F/12

## 6.3 B m/ nh th i trong 8051

- Ngu n xung Clock cho b nh th i
- Ví d: Vi t ch ng trình t o ra m t sóng vuông v i y xung 50% trên chân P1.5. B nh th i Timer0 c dùng t o tr th i gian ch 1. Giá tr kh i t o là FFF2H

```
MOV
                       TMOD, #01
                                               ; Sử dụng Timer0 và chế độ 1(16 bít)
HERE:
               MOV
                       TL0, #0F2H
                                               ; TL0 = F2H, byte thấp
               MOV
                      THO, #0FFH
                                               ; TH0 = FFH, byte cao
                       P1.5
                                               ; Sử dụng chân P1.5
               ACALL DELAY
               SJMP HERE
                                               ; Nạp lại TH, TL
                 delay using timer0.
DELAY:
               SETB TR0
                                               ; Khởi động bộ định thời Timer0
AGAIN:
               JNB
                       TF0, AGAIN
                                               ; Hiển thị cở bộ định thời cho đến khi nó vượt qua FFFFH.
               CLR
                       TR0
                                               : Dừng bộ Timer
               CLR
                                               ; Xoá cờ bộ định thời 0
                       TF0
               RET
```

## ١,

#### 6.3 B m/ nh th i trong 8051

- Ngu n xung Clock cho b nh th i
- ➤ Ví d : Tính toán th i gian tr c a ch ng trình con DELAY n u XTAL = 11,0592MHz

TimeDelay = [12\*(65536 - InitValue)]/F

- = (65536 65522) \*1,085
- = **15,19** micro giây

#### ٧

#### 6.3 B m/ nh th i trong 8051

- Ngu n xung Clock cho b nh th i
- Ví d: Ch ng trình d i t o ra các sóng vuông trên chân P2.5 liên t c b ng vi c s d ng b Timer0 t o ra tr th i gian. Hãy tìm t n s c a sóng vuông n u XTAL=12MHz (không tính t ng phí c a các l nh)

MOV TMOD, #01H ; Chọn Timer0, chế độ 1 (16 bít)
HERE: MOV TL1, #34H ; Đặt byte thấp TL1 = 34H
MOV TH0, #76H ; Đặt byte cao TH1 = 76H
; (giá trị bộ định thời là 7634H)
SETB TR1 ; Khởi động bộ Timer1

AGAIN: JNB TF1, AGAIN ; ở lại cho đến khi bộ định thời đếm qua 0 CLR TR1 ; Dừng bộ định thời.

CPL P1.5 ; Bù chân P1.5 để nhận Hi, L0 CLR TF ; Xoá cờ bô định thời

SJMP AGAIN ; Nạp lại bộ định thời do chế độ 1 không tự

động nạp lại .



#### $6.3 \, \text{B}$ m/ nh th i trong 8051

- Ngu n xung Clock cho b nh th i
- ⊳ ms kin
  - ✓ N u C//T = 1, b nh th i s ho t ng ch b m và ngu n xung clock c c p t bên ngoài.
    - + Timer 0: dùng chân T0 (P3.4)
    - + Timer 1: dùng chân T1 (P3.5)
  - ✓ Các thanh ghi c a b nh th i t ng m i khi x y ra s chuy n tr ng thái t 1 xu ng 0 ngõ vào Tx. Tuy nhiên b V K ph i m t 2 chu k máy nh n bi t s chuy n tr ng thái này, do v y t n s c c i c a ngu n xung clock bên ngoài là 1/24 t n s th ch anh g n trên V K (v i TA 12MHz thì t n s này là 500KHz) 80

# 6.3 B m/ nh th i trong 8051 • Kh i ng, d ng và truy xu t các tha

Kh i ng, d ng và truy xu t các thanh ghi c a b nh th i



## 6.3 B m/ nh th i trong 8051

- Kh i ng, d ng và truy xu t các thanh ghi c a b nh th i
- t ch ho t ng cho b nh th i thông qua thanh ghi TMOD

VD: MOV TMOD, #00010001B

Kh i ng s m ban u (n u c n) cho các thanh ghi nh th i TLx/THx

VD: thi t l p m t kho ng th i gian là 1000μs (v i TA 12MHz) thì ta c n kh i ng cho TLx/THx ch a m t giá tr nó m 1000 xung thì tràn:

 $(FFFFH - 1000) + 1 = FC18H \varnothing THx = 0FCH / TLx = 18H$ 

#### ۲

#### 6.3 B m/ nh th i trong 8051

- Kh i ng, d ng và truy xu t các thanh ghi c a b nh th i
- Kh i ng/d ng các b nh th i b ng các l nh Set/Reset tr c ti p các bit TRx

VD: SETB TR0 ;Kh i ng b nh th i 0 CLR TR0 ;D ng b nh th i 0

> Ki m tra c tràn TFx ho c s d ng ng t xác nh kho ng th i tr ã trôi qua hay ch a.

Lap: JNB TF1, Lap; Den Lap neu TF1 = 0

Có th c/ghi n i dung các thanh ghi c a b nh th i b t c khi nào

83

#### 6.3 B m/ nh th i trong 8051

- ❖ Ví d 1: Vi t ch ng trình con t o tr 200ms dùng b nh th i 0. Bi t t n s c a th ch anh c s d ng là 12MHz
- ❖ Ví d 2: Vi t ch ng trình cho 8051 t o xung vuông t n s 2000Hz, r ng xung 50% trên chân P1.0 s d ng b nh th i 1 (không s d ng ng t). Bi t t n s c a th ch anh c s d ng là 12MHz?
- ❖ Ví d 3: Vi t ch ng trình cho 8051 t o xung vuông t n s 50Hz, r ng xung 50% trên chân P1.0 s d ng b nh th i 1 (không s d ng ng t). Bi t t n s c a th ch anh c s d ng là 12MHz?

#### 6.3 B m/ nh th i trong 8051

- ❖ L p trình b nh th i ch 2:
  - 1. N p giá tr TMOD
  - 2. N p giá tr TH v i giá tr m ban u
  - 3. Kh i ng b nh th i
  - 4. Duy trì hi n th c TF v i l nh "JNB TFx, ích" xem tràn b m ch a. Thoát vòng l p khi TF = 1.
  - 5. Xóa c TF
  - 6. Quay tr 1 i b c 4 vì ch 2 t n p 1 i

85

#### 6.3 B m/ nh th i trong 8051

- ❖ Ví d: V i XTAL = 11.0592MHz, hãy tìm
- a. T n s c a sóng vuông trên chân P1.0
- b. T n s nh nh t có th t o ra b ng ch 2

MOV TMOD, #20H

MOV TH1, #5

SETB TR1

BACK: JNB TF1, BACK

**CPL P1.0** 

CLR TF1

SJMP BACK

## 6.3 B m/ nh th i trong 8051

❖ Ví d : Vi t ch ng trình t o xung vuông t n s 2KHz t i chân P1.7 s d ng Timer 1 ch 8 bit.

87

## 6.3 B m/ nh th i trong 8051

❖ Ví d: Gi s xung ng h c c p t i chân T1, hãy vi t ch ng trình cho b m 1 ch 2 m các xung và hi n th tr ng thái c a s m TL1 trên c ng P2.



- Nguyên lý ho t ng c b n c a c ng truy n thông n i ti p
- Thanh ghi i u khi n và các ch ho t ng c a n i ti p
- Kh i ng và truy xu t các thanh ghi
- ❖ T c baud cho c ng n i ti p
- Ví d

89

## 6.4 C ng n i ti p (UART) trong 8051

- Nguyên lý ho t ng c b n c a c ng truy n thông n i ti p
  - Truy n thông n i ti p: T i m t th i i m ch truy n 1 bit trên
     1 ng (R Kho ng cách xa Ch m)
  - ❖ Truy n thông song song: T i m i th i i m có th truy n 8 bit trên 8 ng riêng bi t ( t − Kho ng cách g n − Nhanh)





- ❖ Nguyên lý ho t ng c b n c a c ng truy n thông n i ti p
  - ❖ Truy n thông n i ti p có hai ph ng th c: ng b (synchronous) và di b (asynchronous).
  - ❖ 8051 h tr ch truy n song công và c hai ph ng th c truy n ng b và d b .





- ❖ M t s chu n truy n thông n i ti p:
  - \* RS232: s d ng truy n thông gi a 2 thi t b
  - \* RS485: truy n thông gi a 2 hay nhi u thi t b
  - USB (Universal Serial Bus): Thay th RS232
  - ❖ I2C (Inter Integrated Circuit): c phát tri n b i hãng Philips.
  - ❖ 8051 c tích h p RS232 v i tên g i: B thu phát di b t ng h p − UART (Universal Asynchronous Receiver Transmitter)

93



## 6.4 C ng n i ti p (UART) trong 8051

- Thanh ghi s d ng trong UART:
  - Thanh ghi SBUF
  - Thanh ghi SCON

#### Thanh ghi SBUF



- Thanh ghi SBUF a ch 99H
- SBUF th c ch t là 2 thanh ghi: c và ghi
- Có hai ng d li u: ng phát (P3.1) và ng thu (P3.0). Vì v y, c ng n i ti p có th truy n và nh n d li u ng th i.

## 6.4 C ng n i ti p (UART) trong 8051

#### Thanh ghi SBUF

- ❖ D li u tr c khi truy n ph i c a n thanh ghi SBUF. Ng c l i, trong ch nh n, SBUF l u d li u tr c khi a n các thanh ghi khác.
- ❖ MOV SBUF, #45H: Truy n d li u ra bên ngoài.
- MOV A, SBUF: L u d li u nh n c vào thanh ghi A.
- M i byte tr c khi truy n i s c óng khung b i 1 bit start và 1 bit stop.
- \* Khi nh n d li u, 8051 lo i b 2 bit start và stop tr c khi ghi d li u vào thanh ghi SBUF.



- Thanh ghi i u khi n và các ch ho t ng c a n i ti p
- > Thanh ghi SCON:

| Bit    | Ký hi u | Mô t                                                        |
|--------|---------|-------------------------------------------------------------|
| SCON.7 | SM0     | Bit0 ch n ch c a c ng n i ti p                              |
| SCON.6 | SM1     | Bit1 ch n ch c a c ng n i ti p                              |
| SCON.5 | SM2     | Bit2 ch n ch c a c ng n i ti p                              |
|        |         | Bit này cho phép truy n thông a x 1ý các ch 2 và 3.         |
| SCON.4 | REN     | Bit cho phép thu. Bit này c set lên 1 cho phép nh n các     |
|        |         | ký t .                                                      |
| SCON.3 | TB8     | Bit phát th 8. Bit th 9 c phát các ch 2 và 3. c             |
|        |         | set/reset b ng ph n m m.                                    |
| SCON.2 | RB8     | Bit thu th 8. Bit th 9 nh n c trong ch 2 và 3.              |
| SCON.1 | TI      | C ng t phát. C này c set ngay khi k t thúc vi c phát m t ký |
|        |         | t, c xoá b i ph n m m.                                      |
| SCON.0 | RI      | C ng t thu. RI =1 ngay sau khi k t thúc vi c thu m t ký t , |
|        |         | c xoá b i ph n m m.                                         |



## 6.4 C ng n i ti p (UART) trong 8051

- Thanh ghi i u khi n và các ch ho t ng c a n i ti p
- SCON c s d ng i u khi n và t các ch ho t ng cho c ng UART.
- C ng n i ti p c a 8051 có 4 ch ho t ng:

| SM0, SM1 | Ch | Mô t           | T c baud                               |
|----------|----|----------------|----------------------------------------|
| 00       | 0  | Thanh ghi d ch | C nh (F <sub>TA</sub> /12)             |
| 01       | 1  | UART 8bit      | Thay i (thi t l p b i b nh th i 1)     |
| 10       | 2  | UART 9bit      | C nh ( $F_{TA}/32$ ho c $F_{TA}/64$ )  |
| 11       | 3  | UART 9bit      | Thay i (thi t l p b i b nh th i 1)  98 |



#### > Ch 0: thanh ghi d ch 8bit :

- $\checkmark$  c ch n v i SM0 = 0, SM1 = 0
- ✓ RxD: thu/phát d li u
- ✓ TxD: phát xung clock d ch bit
- ✓ T c baud c nh và b ng 1/12 t n s TA
- ✓ Khi phát ho c thu d li u 8bit, bit LSB c thu ho c phát tr c tiên
- ✓ Vi c phát d li u c th c hi n b ng l nh ghi d li u vào SBUF.

99

#### Ŋ

#### 6.4 C ng n i ti p (UART) trong 8051

#### > Ch 0: thanh ghi d ch 8bit:

- C ng UART ho t ng ch bán song công. Nó không th truy n và nh n d li u ng th i trên cùng 1 chân RXD
- C ng UART s d ng ph ng th c truy n ng b vì s d ng xung ng b trên chân TXD





8051 serial port in mode 0 - receiving data

#### ٧

#### 6.4 C ng n i ti p (UART) trong 8051

#### > Ch 1: UART 8bit có t c baud thay i:

- $\checkmark$  c ch n v i SM0 = 0, SM1 = 1
- ✓ C ng n i ti p c a 8051 ho t ng nh m t c ng thu phát n i ti p không ng b (UART) 8bit có t c baud thay i.
- ch 1 ta có 10bit c thu trên chân RxD và 10bit c phát trên chân TxD cho m i ký t d li u, bao g m: 1bit start (luôn b ng 0), 8bit d li u, và 1bit stop (luôn là 1). Khi thu, bit stop c a n bit RB8 c a SCON

101

#### ٠,

## 6.4 C ng n i ti p (UART) trong 8051

- > Ch 1: UART 8bit có t c baud thay i:
  - ✓ T c baud c thi t l p b i t c tràn c a b nh th i 1.
  - √Khi ch phát:

✓Vi c phát c th c hi n b ng cách ghi vào SBUF. D li u c d ch bit xu t ra trên chân TxD và b t u b ng bit start, ti p theo là 8bit d li u, r i n bit stop. C ng t phát TI = 1 ngay khi bit stop xu t hi n trên chân TxD.



- > Ch 1: UART 8bit có t c baud thay i
  - ✓ ch thu:
    - ✓Vi c nh n c kh i ng b ng 1 chuy n tr ng thái t 1 xu ng 0 trên chân RxD (bit start).
    - ✓Bit start c b qua và 8 bit d li u c nh n tu n t vào thanh ghi d ch bit c a c ng n i ti p. Khi c 8 bit ã c nh n thì:
      - ✓Bit th 9 (bit stop) c a n bit RB8 c a SCON
      - √8bit d li u n p vào SBUF
      - ✓C ng t thu RI c t lên 1.

103



#### 6.4 C ng n i ti p (UART) trong 8051

- > Ch 2: UART 9 bit có t c baud c nh:
  - $\checkmark$  c ch n v i SM0 = 1, SM1 =0
  - ✓ Ch UART 9 bit có t c baud c nh, bao g m 11bit thu ho c phát: bit start, 8bit d li u, bit d li u th 91 p trình c, bit stop.
  - ✓ Khi phát, bit th 9 là bit TB8 trong thanh ghi SCON. Khi thu, bit th 9 nh n c s c a vào bit RB8.
  - ✓ T c baud ch 2 b ng 1/32 ho c 1/64 t n s th ch anh (tu theo bit SMOD b ng 1 hay 0)

- Ch 3: UART 9bit có t c baud thay i:
  - $\checkmark$  c ch n v i SM0 = 1, SM1 = 1
  - ✓ Ch 3 ho t ng t ng t ch 2 ngo i tr t c baud cl p trình và cung c p b i b nh th i 1

105

#### ٠,

#### 6.4 C ng n i ti p (UART) trong 8051

- \* T c baud cho c ng n i ti p
- > Ch 0: T c baud =  $F_{TA}/12$
- > Ch 1,3: T c baud = t c tràn c a Timer 1 chia cho 16 ho c 32 t ng ng v i bit SMOD b ng 1 hay 0.



Ch 2: T c baud = 1/32 ho c 1/64 t n s th ch anh (tu theo bit SMOD b ng 1 hay 0)







- \* T c baud cho c ng n i ti p
  - ❖ V i XTAL = 12MHz, tìm giá tr TH1 có c t c baud:
    - **\*** 9600
    - **\*** 2400
    - **\*** 1200

109



## 6.4 C ng n i ti p (UART) trong 8051

- \* T c baud cho c ng n i ti p
  - ❖ V i XTAL = 12MHz, SMOD =1, tìm t c baud v i các giá tr c a TH1:
    - **\*** -3
    - **.** -6
    - **\*** -12
    - **\*** -24

### H

#### 6.4 C ng n i ti p (UART) trong 8051

- ❖ L p trình truy n d li u (ch 1)
  - N p giá tr 20H vào thanh ghi TMOD
  - ❖ N p TH1 giá tr m ban u/
  - ❖ N p giá tr 50H vào thanh ghi SCON
  - $\bullet$  B t TR1 = 1 kh i ng Timer1
  - Xóa c ng t TI b ng l nh CLR TI
  - N p byte ký t vào thanh ghi SBUF
  - ❖ Ki m tra c TI b ng l nh JNB TI, label
  - truy n ký t ti p theo quay v b c 5

111

#### r,

## 6.4 C ng n i ti p (UART) trong 8051

- ❖ L p trình truy n d li u (ch 1)
  - ❖ Ví d: Vi t ch ng trình cho 8051 truy n n i ti p ký t "A" v i t c 4800 baud liên t c.

MOV TMOD, #20

MOV TH1, #-6

MOV SCON,#50H

SET TR1

Label MOV SBUF, 'A'

Loop JNB TI, Loop

CLR TI

SJMP Label



- ❖ L p trình truy n d li u (ch 1)
  - ❖ Ví d : Vi t ch ng trình cho 8051 truy n n i ti p chu i ký t "OVER" liên t c v i t c baud b ng 4800

113



## 6.4 C ng n i ti p (UART) trong 8051

- ❖ L p trình nh n d li u (ch 1)
  - N p giá tr 20H vào thanh ghi TMOD
  - N p TH1 giá tr m ban u/
  - ❖ N p giá tr 50H vào thanh ghi SCON
  - $\bullet$  B t TR1 = 1 kh i ng Timer1
  - \* Xóa c ng t RI b ng l nh CLR RI
  - \* Ki m tra c RI b ng l nh JNB TI, label
  - C t n i dung SBUF vào thanh ghi
  - nh n ký t ti p theo quay v b c 5



#### ❖ L p trình nh n d li u (ch 1)

- ❖ Ví d 1: L p trình cho 8051 nh n các byte d li u n i ti p và t chúng vào c ng P1. t t c baud b ng 4800.
- ❖ Ví d 2: L p trình cho 8051 truy n liên t c ch "A" v i t c baud là 19.200

115

#### ٠,

#### 6.4 C ng n i ti p (UART) trong 8051

- Kh i ng và truy xu t các thanh ghi
- > Cho phép thu d li u:
  - ✓ C ng n i ti p c a 8051 ch c phép nh n d li u khi bit REN trong thanh ghi SCON c t b ng 1
  - ✓ The ng bit REN s c t b ng 1 b ng ph n m m u cheng trình.

VD: SETB REN

#### > Bit d li u th 9

✓ Bit d li u th 9 các ch 2 và 3 c ghi vào bit TB8 b ng ph n m m khi phát d li u, và c t bit RB8 ra x lý khi thu.

- Kh i ng và truy xu t các thanh ghi
- > Thêm vào bit ch n l :

✓ Bit th 9 th ng c dùng làm bit ch n l cho m t ký t . a bit ch n l vào khung truy n ta dùng các l nh sau:

MOV A,G c

MOV C,P

MOV TB8,C

MOV SBUF, A

Bit P c set ho c xoá m i chu k máy thi t l p vi c ki m tra ch n cho 8bit trong thanh ch a A.

117

#### ٠,

### 6.4 C ng n i ti p (UART) trong 8051

- ❖ Kh i ng và truy xu t các thanh ghi
- > Các c ng t:
  - ✓ Các c ng t thu RI và ng t phát TI trong thanh ghi SCON u c t lên 1 b ng ph n c ng nh ng ph i c xoá b ng ph n m m.
  - ✓ RI c t lên m c 1 khi k t thúc vi c nh n m t ký t báo b m nh n y. RI = 1 có th sinh ra m t ng t tác ng n V K ho c c ng có th c ki m tra th ng xuyên b ng ph n m m:

LAP: JNB RI, LAP MOV A,SBUF CLR RI



- Kh i ng và truy xu t các thanh ghi
- Các c ng t:

✓ TI =1 khi k t thúc vi c phát m t ký t báo r ng b
m phát ang r ng, có th truy n ký t ti p theo. Do
v y tr c khi truy n m t ký t ta ph i ki m tra TI
bi t ký t tr c ó ã c truy n xong hay ch a, ch
khi TI = 1 hay ký t tr c ó ã c truy n xong thì
ta m i truy n ký t ti p theo. i u này tránh vi c ghi
è d li u. Các l nh th ng dùng:

CHO: JNB TI, CHO ;Ch n khi ký t tr c ó ã truy n xong CLR TI ; xoá TI MOV SBUF,A ; truy n ký t m i

119

#### ١,

### 6.4 C ng n i ti p (UART) trong 8051

- Ví d 1: Truy n ký t "A" liên t c ra c ng UART v i t c baud b ng 9600 ch 3, có ki m tra ch n. S d ng Timer1.
- ❖ Ví d 2: L p trình nh n d li u t c ng UART v i t c baud b ng 4800 ch 3, có ki m tra 1 . S d ng Timer1.



- ❖ T ch c và x lý ng t trong V K 8051
- Thi t k ch ng trình s d ng ng t
- ❖ Ng t c a b m/ nh th i
- Ng tc ac ng n i ti p
- Các ng t ngoài

121



#### 6.5 Ho t ng ng t trong 8051

- ❖ T ch c và x lý ng t trong V K 8051
- V K 8051 có 5 ngu n ng t: hai ng t ngoài, hai ng t c a các b nh th i, và m t ng t c a c ng n i ti p.
- Sau khi c p ngu n ho c Reset t t c các ng t u b c m sau ó chúng s c cho phép b ng ph n m m. Vi c cho phép/c m m t ng t c th c hi n thông qua vi c t ho c xoá các bit t ng ng trong thanh ghi cho phép ng t IE.
- ➤ 8051 có 2 s x lý u tiên ng t: s chu i vòng và s hai m c u tiên. S chu i vòng c thi t 1 p t khi s n xu t vi m ch còn s u tiên ng t c 1 p trình b i ng i s d ng.



- ❖ T ch c và x lý ng t trong V K 8051
- Thanh ghi cho phép ng t IE

| Bit  | Ký hi u | /ch bit | Mô t                                      |  |
|------|---------|---------|-------------------------------------------|--|
| IE.7 | EA      | 0AFH    | Bit cho phép ng t toàn c c                |  |
| IE.6 | -       | 0AEH    | Không dùng                                |  |
| IE.5 | -       | 0ADH    | Không dùng                                |  |
| IE.4 | ES      | 0ACH    | Bit cho phép ng t do c ng n i ti p        |  |
| IE.3 | ET1     | 0ABH    | Bit cho phép ng t do b nh th i 1 (TIMER1) |  |
| IE.2 | EX1     | 0AAH    | Bit cho phép ng t ngoài 1 (INT1)          |  |
| IE.1 | ET0     | 0A9H    | Bit cho phép ng t do b nh th i 0 (TIMER0) |  |
| IE.0 | EX0     | 0A8H    | Bit cho phép ng t ngoài 0 (INT0)          |  |

123



#### 6.5 Ho t ng ng t trong 8051

- ❖ T ch c và x lý ng t trong V K 8051
- > Thanh ghi cho phép ng t IE
  - ✓ Vi c cho phép hay c m m t ng t c th c hi n b ng cách t ho c xoá bit t ng ng trong thanh ghi cho phép ng t IE
  - ✓ cho phép m t ng t nào ó thì bit cho phép c a
     ng t t ng ng ph i c t b ng 1, ng th i bit
     cho phép ng t toàn c c c ng ph i c t b ng 1

VD: Các l nh cho phép ng t ngoài 1

SETB EX1 ;Cho phép ng t ngoài 1 SETB EA ;Cho phép các ng t

ho c dùng l nh  $\,$  MOV IE,#10000100B



- ❖ T ch c và x lý ng t trong V K 8051
- > Thanh ghi u tiên ng t IP

| Bit  | Ký   | /ch bit | Mô t                              |
|------|------|---------|-----------------------------------|
|      | hi u |         |                                   |
| IP.7 | 1    | 0BFH    | Không dùng                        |
| IP.6 | -    | 0BEH    | Không dùng                        |
| IP.5 | -    | 0BDH    | Không dùng                        |
| IP.4 | PS   | 0BCH    | Bit u tiên ng t cho c ng n i ti p |
| IP.3 | PT1  | 0BBH    | Bit u tiên ng t cho b nh th i 1   |
| IP.2 | PX1  | 0BAH    | Bit u tiên ng t cho ng t ngoài 1  |
| IP.1 | PT0  | 0B9H    | Bit u tiên ng t cho b nh th i 0   |
| IP.0 | PX0  | 0B8H    | Bit u tiên ng t cho ng t ngoài 0  |



#### 6.5 Ho t ng ng t trong 8051

- ❖ T ch c và x lý ng t trong V K 8051
- > Thanh ghi u tiên ng t IP
  - ✓ IP cho phép ta có th t m t trong hai m c u tiên cho m t ng t. Sau c p ngu n hay Reset IP = 0.
  - ✓ M t ng t có bit u tiên b ng 1 s có m c u tiên cao h n ng t có bit u tiên b ng 0. Khi hai ng t xu t hi n ng th i ng t có m c u tiên cao h n s c b V K ph c v tr c.
  - ✓ N u có ng t v i m c u tiên cao xu t hi n, ch ng trình ph c v cho ng t có m c u tiên th p h n s ph i t m d ng V K chuy n t i ch ng trình ph c v cho ng t có m c u tiên cao h n.



- ❖ T ch c và x lý ng t trong V K 8051
- > Chu i vòng
  - ✓ N u có hai ng t có cùng m c u tiên xu t hi n ng th i, chu i vòng s xác nh ng t nào c ph c v tr c. Chu i vòng này s là (m c u tiên gi m d n):
    - + ng t ngoài 0
    - + ng t do b nh th i 0
    - + ng t ngoài 1
    - + ng t do b nh th i 1
    - + ng t do c ng n i ti p.

127



#### 6.5 Ho t ng ng t trong 8051

- ❖ T ch c và x lý ng t trong V K 8051
- > X lý ng t
  - ✓ Khi có m t ng t xu t hi n và c CPU ch p nh n, ch ng trình chính s b ng t. Và CPU s th c hi n các thao tác sau:
    - + Hoàn t t vi c th c thi l nh hi n hành
    - + C t b m ch ng trình PC vào ng n x p
- + B m ch ng trình PC c n p a ch vector c a ch ng trình ph c v ng t t ng ng.
  - + Ch ng trình ph c v ng t c th c thi.

Khi th c thi ch ng trình ph c v ng t, n u g p 1 nh RETI thì V K s quay tr 1 i ch ng trình chính.



❖ T ch c và x lý ng t trong V K 8051

#### > X lý ng t

✓ Các nguyên nhân ng t s tích c c m i khi c ng t t ng ng b ng 1:

| Ng t                    | С   | V trí trong thanh ghi SFR |
|-------------------------|-----|---------------------------|
| Ng t ngoài 0 (INT0)     | IE0 | TCON.1                    |
| Ng t ngoài 1 (INT1)     | IE1 | TCON.3                    |
| Ng t do TIMER0          | TF0 | TCON.5                    |
| Ng t do TIMER1          | TF1 | TCON.7                    |
| Ng t nh n c a c ng NT   | RI  | SCON.0                    |
| Ng t truy n c a c ng NT | TI  | SCON.1                    |

120



#### 6.5 Ho t ng ng t trong 8051

❖ T ch c và x lý ng t trong V K 8051

#### Các Vector ng t

- √ Khi m t ng t c V K áp ng, giá tr n p cho b m ch ng trình PC c g i là vector ng t. Vector ng t là a ch b t u c a ch ng trình ph c v ng t c a ng t t ng ng
- ✓ Khi m t ch ng trình ph c v ng t c th c hi n b i V K thì c gây ra ng t s t ng b xoá v 0 b i ph n c ng. Riêng i v i c ng truy n thông n i ti p thì các c TI, RI ph i c xoá b ng ph n m m.



- T ch c và x lý ng t trong V K 8051
- Các Vector ng t

| Ng t do               | С          | a ch vector |
|-----------------------|------------|-------------|
| Reset h th ng         | RST        | 0000Н       |
| Ng t ngoài 0 (INT0)   | IE0        | 0003H       |
| Ng tTIMER0            | TF0        | 000BH       |
| Ng t ngoài 1 (INT1)   | IE1        | 0013H       |
| Ng tTIMER1            | TF1        | 001BH       |
| Ng t do c ng n i ti p | RI ho c TI | 0023H       |

131



#### 6.5 Ho t ng ng t trong 8051

- Thi t k ch ng trình s d ng ng t
- Dùng khung ch ng trình nh ã trình bày ph n 6.2
- Gi a các vector ng t có kho ng cách là 8byte, do v y n u m t ch ng trình ph c v ng t có kích th c nh h n ho c b ng 8byte thì ta có th t ch ng trình này ngay trong vùng vector ng t.
- Nu các ch ng trình ph c v ng t có kích th c l n h n 8byte thì ta ph i chuy n các ch ng trình này n m t n i khác trong b nh ch ng trình tránh tràn sang i m nh p c a ng t khác.

6.5 Ho t ng ng t trong 8051 Thi tk ch ng trình s d ng ng t ng trình ng t có kích th c nh Ch ORG 0000H External code memory LJMP MAIN ORG 000BH INT: **RETI** Main program MAIN: . . . . . . . . 0030 **END** 002F Reset and interrupt entry points LJMP main 133



#### 6.5 Ho t ng ng t trong 8051 • Ng tc ab m/ nh th i Vi t ch ng trình cho 8051 t o xung vuông t n s 2000Hz, xung 50% trên chân P2.0 s d ng b nh th i 1 (s d ng ng t). Bi t t ns c a th ch anh c s d ng là 12MHz? ORG 0000H LJMP MAIN ORG 000BH CPL P2.0 **RETI** ORG 0030H MOV TMOD, #20H MAIN: MOV TH1,#6 MOV IE,#88H **SETB** TR1 HERE: SJMP **HERE**



❖ Ng t c a b m/ nh th i

Vi t ch  $\,$  ng trình cho 8051 nh  $\,$ n liên t  $\,$ c  $\,$ d  $\,$ li  $\,$ u t  $\,$ c  $\,$ ng  $\,$ P0 sau  $\,$ ó  $\,$ a ra  $\,$ c  $\,$ ng  $\,$ P1. Trong lúc này  $\,$ c  $\,$ n t  $\,$ o xung vuông có chu  $\,$ k  $\,$ 200microgiây trên chân  $\,$ P2.1.  $\,$ f $_{osc} = 11.0592MHz.$ 

137



#### 6.5 Ho t ng ng t trong 8051

- Ng t ngoài
  - ❖ B vi i u khi n 8051 có hai ng t ph n c ng bên ngoài là chân 12 (P3.2) và chân 13 (P3.3) dùng cho ng t INT0 và INT1
  - Có hai m c kích ho t cho các ng t ph n c ng ngoài: ng t theo m c và ng t theo s n.

- Ng t ngoài
  - Ng t theo m c: chân ng t ph i c gi m c th p cho n khi b t u th c hi n trình ph c v ng t ISR.



## 6.5 Ho t ng ng t trong 8051

- Ng t ngoài
  - Ng t theo c nh: S n xu ng c a xung t i các chân INT0 và INT1 c gi b i các bit TCON.1 và TCON.3



#### Ng t ngoài theo m c:

Ví d ng t theo m c: M i khi công t c c b t xu ng m c th p thì èn LED sáng trong m t kho ng th i gian nh t nh.



141

## 6.5 Ho t ng ng t trong 8051

#### Ng t ngoài theo m c:

**END** 

**ORG** 0000H LJMP MAIN ORG 0013H 8051 SETB P1.3 P1.3 MOV R3,#255 INTI HERE: DJNZ R3, HERE CLR P1.3 **RETI** ORG 0030H MAIN: MOV IE, #84H SJMP

#### Ng t ngoài theo c nh:

M i khi công t c c chuy n tr ng thái t cao xu ng th p thì èn sáng trong m t kho ng th i gian nh t nh. N u công t c c gi trong m t kho ng th i gian thì èn không c sáng liên t c.



143

## 6.5 Ho t ng ng t trong 8051

#### Ng t ngoài theo s n:

ORG 0000H LJMP MAIN ORG 0013H 8051 **SETB** P1.3 MOV R3,#255 INTI HERE: DJNZ R3, HERE CLR P1.3 **RETI** ORG 0030H

MAIN: MOV IE, #84H
SETB TCON.2
SJMP \$

ENID



- ❖ Ví d 1:Vi t ch ng trình nh n d li u t c ng P1 và g i liên t c n c ng P2 trong khi ó d li u i vào t c ng n i ti p c g i n P0. Gi thi t f<sub>osc</sub> = 11.059MHz, t c truy n là 9600 baud.
- Ví d 2: Vi t o n l nh ch nh n d li u t m t thi t b ngoài g i n 8051 qua c ng n i ti p (UART 8 bit, 9600 baud). N u nh n c ký t "A" thì b t sáng LED, n u nh n c ký t "B" thì t t LED. Bi t LED c i u khi n qua c ng P1.3. S d ng ng t c ng n i ti p. F<sub>ocs</sub> = 11.059MHz